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DETAILED ACTION 

1. Claims 8-9, 14-16, 21-37, and new claims 38-42 have been considered. New claims 38- 
42 have been added as per Applicant's request. 

Papers Submitted 

2. It is hereby acknowledged that the following papers have been received and placed of 
record in the file: RCE as filed on 07 March 2005 and Amendment as field 07 March 2005. 

Election/Restrictions 

3. Newly submitted claims 38-42 directed to an invention that is independent or distinct 
from the invention originally claimed for the following reasons: 

I. Claims 8-9, 14-16, and 21-37, drawn to allocating entries into a speculative and 
architectural branch target buffers, classified in class 712, subclass 238. 

II. Claims 38-42, drawn to selecting an entry from a speculative or architectural 
branch target buffer for branch prediction, classified in class 712, subclass 239. 

4. Inventions I and II are related as combination and subcombination. Inventions in this 
relationship are distinct if it can be shown that (1) the combination as claimed does not require 
the particulars of the subcombination as claimed for patentability, and (2) that the 
subcombination has utility by itself or in other combinations (MPEP § 806.05(c)). In the instant 
case, the combination as claimed does not require the particulars of the subcombination as 
claimed because the entries within the speculative and architectural branch target buffers can be 
allocated in any manner. The subcombination has separate utility such as allocating entries into 
a system with speculative and non-speculative branch target buffers that selects an entry based 
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upon different criteria from that in the independent claim and whose buffers do not have the 
fields claimed in the dependent claims. 

5. Since applicant has received an action on the merits for the originally presented 
invention, this invention has been constructively elected by original presentation for prosecution 
on the merits. Accordingly, claims 39-42 withdrawn from consideration as being directed to a 
non-elected invention. See 37 CFR 1.142(b) and MPEP § 821.03. 

Claim Rejections - 35 USC §102 

6. The following is a quotation of the appropriate paragraphs of 35 U.S. C. 102 that form the 
basis for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 

(e) the invention was described in (1) an application for patent, published under section 122(b), by another filed 
in the United States before the invention by the applicant for patent or (2) a patent granted on an application for 
patent by another filed in the United States before the invention by the applicant for patent, except Uiat an 
international application filed under the treaty defined in section 351(a) shall have the effects for purposes of this 
subsecfion of an application filed in the United States only if the international application designated the United 
States and was published under Article 21(2) of such treaty in the English language. 

7. Claims 8-9, 14-16, 21-24, 28-29, and 33-34 are rejected under 35 U.S.C. 102(e) as being 
taught by Lempel, U.S. Patent Number 5,978,909 (herein referred to as Lempel). 

8. The applied reference has a common assignee with the instant application. Based upon 
the earlier effective U.S. filing date of the reference, it constitutes prior art under 35 U.S.C. 
102(e). This rejection under 35 U.S.C. 102(e) might be overcome either by a showing under 37 
CFR 1. 132 that any invention disclosed but not claimed in the reference was derived from the 
inventor of this application and is thus not the invention "by another," or by an appropriate 
showing under 37 CFR 1.131. 

9. Referring to claim 8, Lempel has taught a method, comprising: 
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a. Speculatively allocating a first branch entry for a conditional branch in a 
speculative branch target buffer (SBTB) prior to execution of the conditional 
branch responsive to decoding the conditional branch and finding no branch entry 
in an architectural branch target buffer (ABTB) corresponding to the conditional 
branch (Lempel column 4, line 53 to column 3, line 23; column 5, line 59 to 
column 6, line 15; column 6, Hne 49 to column 7, line?; Figure 2); 

b. Speculatively allocating a second branch entry for the conditional branch in the 
SBTB responsive to a subsequent failed attempt to locate a branch entry in the 
ABTB corresponding to the conditional branch (Lempel column 4, line 53 to 
column 3, line 23; column 5, line 59 to column 6, line 15; column 6, line 49 to 
column 7, line7; Figure 2); 

c. Allocating a third branch entry for the conditional branch in the ABTB after 
retirement of the conditional branch (Lempel column 4, line 53 to column 3, line 
23; column 5, line 59 to column 6, line 15; column 6, line 49 to column 7, line7; 
Figure 2); and 

d. Subsequently performing branch prediction for the conditional branch by 
determining a predicted target address branch based upon branch data associated 
with the second branch entry (Lempel column 4, Hne 53 to column 3, line 23; 
column 5, line 59 to column 6, line 15; column 6, Hne 49 to column 7, Hne7; 
Figure 2). 

10. Referring to claim 9, Lempel has taught speculatively updating branch data associated 
with the first branch entry after said performing branch prediction for the conditional branch 
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(Lempel column 4, line 53 to column 3, line 23; column 5, line 59 to column 6, line 15; column 
6, line 49 to column 7, line?; Figure 2). 

1 1 . Referring to claim 14, Lempel has taught a machine-readable medium having stored 
thereon data representing sets of instructions, the sets of instructions which, when executed by a 
machine, cause the machine to: 

a. Speculatively allocate a first branch entry for a conditional branch in a speculative 
branch target buffer (SBTB) prior to execution of the conditional branch 
responsive to decoding the conditional branch and finding no branch entry in an 
architectural branch target buffer (ABTB) corresponding to the conditional branch 
(Lempel column 4, line 53 to column 3, line 23; column 5, line 59 to column 6, 
line 15; column 6, line 49 to column 7, line7; Figure 2); 

b. Speculatively allocate a second branch entry for the conditional branch in the 
SBTB responsive to a subsequent failed attempt to locate a branch entry in the 
ABTB corresponding to the conditional branch (Lempel column 4, line 53 to 
column 3, line 23; column 5, line 59 to column 6, line 15; column 6, line 49 to 
column 7, Une7; Figure 2); 

c. Allocate a third branch entry for the conditional branch in the ABTB after 
retirement of the conditional branch (Lempel column 4, line 53 to column 3, line 
23; column 5, line 59 to column 6, line 15; column 6, line 49 to column 7, line7; 
Figure 2); and 

d. Subsequently perform branch prediction for the conditional branch by 
determining a predicted target address branch based upon branch data associated 
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with the second branch entry (Lempel column 4, line 53 to column 3, line 23; 
column 5, line 59 to column 6, line 15; column 6, line 49 to column 7, line?; 
Figure 2). 

12. Referring to claim 15, Lempel has taught wherein the sets of instructions which, when 
executed by the machine, further cause the machine to speculatively update branch data 
associated with the first branch entry after said performing branch prediction for the conditional 
branch (Lempel column 4, line 53 to column 3, line 23; column 5, line 59 to column 6, line 15; 
column 6, line 49 to column 7, line?; Figure 2). 

13. Referring to claim 21, Lempel has taught a processor, comprising: 

a. A fetch unit to speculatively retrieve instruction data for processing by an 
instruction pipeline (Lempel column 3, line 4? to column 4, line 8; .column 4, 
lines 20-43; and Figure 1); and 

b. A branch prediction circuit, coupled to the fetch unit, to predict final target 
addresses for branch instructions contained within the instruction data (Lempel 
column 4, lines 9-43 and Figure 1), the branch prediction circuit including 

i. A speculative branch target buffer (SBTB) cache having a plurality of 

branch entries to maintain speculative branch data associated with in-flight 
branches, the speculative branch data including a speculative history of 
taken/not-taken outcomes associated with the in-flight branches (Lempel 
column 4, line 53 to column 3, line 23; column 5, line 59 to column 6, line 
15; column 6, line 49 to column ?, line?; Figure 2), and 
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ii. An architectural branch target buffer (ABTB) cache, coupled to the SBTB 
cache, the ABTB having a plurality of branch entries to maintain 
architectural branch data including the actual taken/not-taken outcomes 
associated with retired conditional branches (Lempel column 4, line 53 to 
column 3, line 23; column 5, line 59 to column 6, line 15; column 6, line 
49 to column 7, line7; Figure 2). 

14, Referring to claim 22, Lempel has taught wherein the SBTB cache comprises a FIFO 
having entries corresponding to each of a plurality of pipeline stages of the instruction pipeline 
(Lempel column 4, line 53 to column 3, line 23; column 5, line 15 to column 6, line 15; column 
6, line 49 to column 7, line7; Figure 2). 

15. Referring to claim 23, Lempel has taught wherein the branch data includes a speculative 
history field representing the speculative taken or not-taken history of the branch for a 
predetermined window of executions of the branch, and wherein said speculatively updating 
branch data comprises updating the speculative history field to reflect the taken or not-taken 
status of its most recent execution (Lempel column 5, line 15 to column 6, line 15 and Figure 3). 

16. Referring to claim 24, Lempel has taught wherein the branch data includes a speculative 
history field representing the speculative taken or not-taken history of the branch for a 
predetermined window of executions of the branch, and wherein said speculatively updating 
branch data comprises updating the speculative history field to reflect the taken or not-taken 
status of its most recent execution (Lempel column 5, line 15 to column 6, line 15 and Figure 3). 

17, Referring to claim 28, a branch prediction circuit, comprising: 
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a. A speculative branch target buffer (SBTB) cache having a plurality of branch 
entries to maintain speculative branch data associated with in-flight branches, the 
speculative branch data including a speculative history of taken/not-taken 
outcomes associated with the in-flight branches, wherein the SBTB cache 
includes a FIFO having entries corresponding to each of a pluraUty of pipehne 
stages of a processor instruction pipeline (Lempel column 4, Une 53 to column 3, 
line 23; column 5, line 59 to column 6, line 15; column 6, line 49 to column 7, 
line?; Figure 2); 

b. An architectural branch target buffer (ABTB) cache coupled to the SBTB cache, 
the ABTB cache having a plurality of branch entries to maintain architectural 
branch data including actual taken/not-taken outcomes associated with retired 
conditional branches (Lempel column 4, line 53 to column 3, line 23; column 5, 
line 59 to column 6, line 15; column 6, line 49 to column 7, line7; Figure 2); and 

c. A target address generator coupled to the SBTB cache and the ABTB cache, the 
target address generator to determine a predicted target address for a branch 
prediction based upon the speculative branch data and the architectural branch 
data (Lempel column 4, line 53 to column 3, line 23; column 5, line 59 to column 
6, line 15; column 6, line 49 to column 7, line?; Figure 2). 

18. Referring to claim 29, Lempel has taught a fetch unit to speculatively retrieve instruction 
data for processing by the processor instruction pipeline (Lempel column 3, line 4? to column 4, 
line 8; column 4, lines 20-43; and Figure 1). 

19. Referring to claim 33, Lempel has taught a method, comprising: 
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a. Maintaining speculative branch data associated with in-flight branches using a 
speculative branch target buffer (SBTB) cache having a plurality of branch 
entries, the speculative branch data including a speculative history of taken/not- 
taken outcomes associated with the in-flight branches, wherein the SBTB cache 
includes a FIFO having entries corresponding to each of a plurality of pipeline 
stages of a processor instruction pipeline (Lempel column 4, line 53 to column 3, 
line 23; column 5, line 59 to column 6, line 15; column 6, line 49 to column 7, 
line?; Figure 2); 

b. Maintain architectural branch data using a plurality of branch entries of an 
architectural branch target buffer (ABTB) cache coupled to the SBTB cache, the 
architectural branch data including the actual taken/not-taken outcomes associated 
with retired conditional branches (Lempel column 4, line 53 to column 3, line 23; 
column 5, line 59 to column 6, line 15; column 6, line 49 to column 7, line7; 
Figure 2); and 

c. Determine a predicted target address for a branch prediction based upon the 
speculative branch data and the architectural branch data, the determining of the 
predicted target address is performed using a target address generator coupled to 
the SBTB cache and the ABTB cache (Lempel column 4, line 53 to column 3, 
line 23; column 5, line 59 to column 6, line 15; column 6, line 49 to column 7, 
line7; Figure 2). 
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20. Referring to claim 34, Lempel has taught a fetch unit to speculatively retrieve instruction 
data for processing by the processor instruction pipeline (Lempel column 3, line 47 to column 4, 
line 8; column 4, hnes 20-43; and Figure 1). 

Claim Rejections - 35 USC §103 

21. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in 
section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are 
such that the subject matter as a whole would have been obvious at the time the invention was made to a person 
having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 

22. Claims 25-27, 30-32, and 35-37 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Lempel, U.S. Patent Number 5,978,909 (herein referred to as Lempel) as 
applied to claims 21, 28, and 33 above, in view of Applicant's admitted prior art in the 
Background of the Invention (herein referred to as Prior Art). Lempel has not taught: 

a. Wherein the SBTB is dual-ported (Applicant's claims 25, 30, and 35); 

b. Wherein the SBTB is single-ported (Apphcant's claims 26, 3 1 and 36); and 

c. Wherein the ABTB is single-ported (AppUcant's claims 27, 32, and 37). 

23 . Prior Art has taught: 

a. Wherein the SBTB is dual-ported (Applicant's claims 25, 30, and 35) (Prior Art 
page 5, lines 1-5); 

b. Wherein the SBTB is single-ported (Apphcant's claims 26, 31 and 36) (Prior Art 
page 5, lines 1-5); and 

c. Wherein the ABTB is single-ported (Apphcant's claims 27, 32, and 37) (Prior Art 
page 5, lines 1-5). 
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24. As stated in Prior Art and known to a person of ordinary skill in the art, the 
reading/writing ports allow the SBTB to be accessed by the various pipeline stages for 
information (Prior Art page 5, lines 1-5) and it is necessary for the information to be available to 
the rest of the device for it to function properly. A person of ordinary skill in the art would have 
recognized that the read/write ports allows the information to be accessed by the various pipeline 
stages and the rest of the device. Therefore, it would have been obvious to a person of ordinary 
skill in the art at the time this invention was made to incorporate the read/write ports of Prior Art 
in the device of Lempel to allow information to be accessed by the various pipeline stages and 
the rest of the device. 

Response to Arguments 

25. Applicant's arguments filed 07 March 2005 have been fully considered but they are not 
persuasive. Applicant argues in essence on pages 9-10 

, . .Although Lempel discloses a SBTB and a BTB, Lempel fails to disclose or 
reasonably suggest an architectural branch target buffer (ABTB\ are cited by 
claim 9. For example, figure 2 from Lempel discloses dynamic predictor 135 
which includes BTB 145 and SBTB 150. . . In contrast, figure 4B of the 
specification shows branch prediction unit 420 which includes BTB 470. BTB 
470 includes SBTB 490 andABTB 480 . .. Lempel fails to disclose or reasonably 
suggest the use of an ABTB . . . 

26. This has not been found persuasive. The claim language claim language does not 
distinguish the ABTB from a BTB nor is there any suggestion of a distinction between the 
ABTB and the BTB. The claim language also does not suggest or make clear that the ABTB and 
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SBTB are part of the BTB, as alluded to in the arguments by reference to Applicant's figure 4, 
elements 470, 480, and 490. In response to appUcant's argument that the references fail to show 
certain features of appUcant's invention, it is noted that the features upon which applicant reUes 
(i.e., the distinction between the ABTB and BTB) are not recited in the rejected claim(s). 
Although the claims are interpreted in light of the specification, limitations from the specification 
are not read into the claims. See In re Van Geuns, 988 F.2d 1 181, 26 USPQ2d 1057 (Fed. Cir. 
1993), 

27. Applicant's arguments with respect to claims 38-42 have been considered but are moot in 
view of the election by original presentation above 

Conclusion 

28. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Aimee J. Li whose telephone number is (571) 272-4169. The 
examiner can normally be reached on M-T 7:30am-5 :00pm. 

29. If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Eddie Chan can be reached on (571) 272-4162. The fax phone number for the 
organization where this application or proceeding is assigned is 703-872-9306. 

30. Information regarding the status of an apphcation may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). 
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